草庐IT

C++ 优化

全部标签

javascript - 优化 JavaScript 中的 JSON 查询性能

我有一个10MB的JSON文件,结构如下(10k个条目):{entry_1:{description:"...",offset:"...",value:"...",fields:{field_1:{offset:"...",description:"...",},field_2:{offset:"...",description:"...",}}},entry_2:.........我想实现一个自动完成输入字段,该字段将在搜索多个属性时尽快从该文件中获取建议。例如,查找所有包含某些子字符串的条目名称、字段名称和描述。方法一:我试图将嵌套展平为一个字符串数组:"entry_1|descr

xml - 优化 Haskell XML 解析器

我目前正在尝试使用Haskell,并且非常享受这种体验,但我正在针对具有一些相当严格的性能要求的真实项目对其进行评估。我的任务的第一步是处理维基百科的完整(无历史)转储(bzipped)——总共压缩了大约6Gb。在python中,对每个原始页面(总共约1000万)进行完整提取的脚本在我的盒子上需要大约30分钟(作为引用,使用pull解析器的scala实现需要大约40分钟)。我一直在尝试使用Haskell和ghc复制这种性能,并且一直在努力匹配它。我一直在使用Codec.Compression.BZip进行解压缩,并使用hexpat进行解析。我使用惰性字节串作为元素文本类型的hexpat

高性能计算实验——矩阵乘法基于MPI的并行实现及优化

高性能计算实验——矩阵乘法基于MPI的并行实现及优化1.实验目的1.1.通过MPI实现通用矩阵乘法1.2.基于MPI的通用矩阵乘法优化1.3.改造实验1成矩阵乘法库函数2.实验过程和核心代码2.1.通过MPI实现通用矩阵乘法2.2.通用矩阵乘法优化2.3.改造实验1成矩阵乘法库函数3.实验结果3.1.通过MPI实现通用矩阵乘法3.2.基于MPI的通用矩阵乘法优化3.3.改造实验1成矩阵乘法库函数4.实验感想1.实验目的1.1.通过MPI实现通用矩阵乘法熟练掌握MPI编程方法,并将通用矩阵乘法转为MPI并行实现,进一步加深MPI的使用与理解。1.2.基于MPI的通用矩阵乘法优化进一步熟悉MPI矩

C 代码在 Windows 上比在 Linux 上慢

我正在开发一个项目,该项目将针对32位和64位Windows和Linux进行构建。该项目基于为文本文件加载字符串、对其进行处理并将结果写入SQLite3数据库。在Linux上,它达到每秒近400k个序列,由GCC编译,没有任何优化。然而在Windows上它卡在每秒100k个序列,在没有任何优化的情况下在VS2010上编译。我尝试在编译器中使用优化,但没有任何改变。这样对吗?Windows上的C代码运行速度较慢?编辑:我想我需要更清楚地说明一些要点。我在启用和禁用代码优化的情况下进行了测试。性能没有改变,可能是因为我的程序的瓶颈是浪费时间从HD读取数据。该程序利用了并行计算的优势。有一个

c - 为什么 Windows 要求导入 DLL 数据?

在Windows上,可以从DLL加载数据,但需要通过导入地址表中的指针进行间接访问。因此,编译器必须知道正在访问的对象是否是使用__declspec(dllimport)从DLL导入的。类型说明符。这很不幸,因为这意味着设计用作静态库或动态库的Windows库的header需要知道程序链接到哪个版本的库。此要求不适用于函数,这些函数是为DLL透明地模拟的,stub函数调用实际函数,其地址存储在导入地址表中。在Linux上,动态链接器(ld.so)将所有链接数据对象的值从共享对象复制到每个进程的私有(private)映射区域。这不需要间接寻址,因为私有(private)映射区域的地址是模

c - 如何从 ml64.exe(MSVC 64 位 X64 汇编程序)访问线程本地存储?

以下C函数尝试使用线程局部存储变量以线程安全的方式防止多核代码中的递归。但是,由于有些复杂的原因,我需要在X64汇编程序(IntelX86/AMD64位)中编写此函数,并使用VC2010中的ml64.exe进行汇编。如果我使用全局变量,我知道如何执行此操作,但我不确定如何使用具有__declspec(thread)的TLS变量正确执行此操作。__declspec(thread)inttls_VAR=0;voidnorecurse(){if(0==tls_VAR){tls_VAR=1;DoWork();tls_VAR=0;}}注意:这是VC2010踢出来的功能。但是,MASM(ml64.

c# - 为 .NET 开发和调试优化 IIS7

似乎我将近一半的时间都花在.NET上,等待IIS启动而不是实际开发。这很简单:每当我有机会访问代码隐藏文件并刷新时,IIS都需要15秒到一分多钟的时间来回收。有什么办法可以改善吗?真让人抓狂。我从事网站项目(而非Web应用程序项目),运行Windows7并在.NET4框架中工作。我的机器才用了几个月,有一个SSD,所以我认为硬件不应该是瓶颈。此外,大多数时候我什至没有实际调试应用程序,尽管它运行得更慢。 最佳答案 编辑无论您使用哪种类型的IIS,加快速度的最佳方法之一是创建一个RAM驱动器并指向您的TEMP,尤其是ASP.NET临时

c - 为什么 `fseek(..., 0, SEEK_CUR)` 在 Windows 上失败?

我已经测试了以下C代码#includeintmain(){FILE*file=fopen("ans.txt","r+");printf("%ld",ftell(file));//prints0fgetc(file);printf("%ld",ftell(file));//prints-18printf("%d",fseek(file,0,SEEK_CUR));//-1printf("%ld",ftell(file));//prints150fclose(file);return0;}在win10上使用MinGW-W64(gcc版本7.1.0(x86_64-posix-seh-rev0,

C malloc + free 不断增加内存占用

我有一个处理大量数据(100+KB)的C应用程序。我正在使用malloc()来分配所需的内存。(char*)malloc(argLen+18+2)执行后,我使用free释放分配的内存。据我所知,由于某些原因,释放的内存没有返回给操作系统。我的问题是,当我再次运行该程序时,它并没有重新使用分配的内存,而是不断增加我的应用程序的内存使用量。编辑:对于造成的困惑,我深表歉意。该进程是一个WebSocket服务。除非有意停止,否则它不会终止。这是否意味着该进程将继续增加其内存使用量并且不会释放分配的内存,除非我手动重新启动它? 最佳答案 I

c++ - 我的程序在 Windows 机器上崩溃但在 Linux 上运行正常

我尝试在我的笔记本电脑(Win10)上编写Ackermann函数,但是程序在更高的值时崩溃了,而不是继续计算几分钟或几小时。我的friend在他的机器(SUSE)上尝试了相同的代码,它工作得很好,然后我们在学校服务器(CentOS)上尝试了它,但它再次崩溃。编辑:它也在服务器上工作,只需要再试一次。它也适用于我们尝试过的另一台服务器……所有这些都在Linux上。我们怀疑它背后是堆栈溢出,但这很奇怪,因为值还没有那么高。那么我如何能够在这个系统上执行递归函数呢?谢谢大家的回答。我只是好奇它为什么会发生以及如何让它在我的机器上运行。我尝试同时使用C和C++,但没有任何变化。#include